<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
<meta name="viewport"
      content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">

    <meta name="author" content="Janmas">



    <meta name="description" content="Janmas！一个又菜又爱玩的程序猿。不停的在立Flag，又一直在凭实力打着自己的脸。">


    <meta name="keywords" content="Janmas,Blog,墨鱼">


<title>
    vim键位整理 |
    
    Janmas</title>



    <link rel="icon" href="/favicon.ico">



    <!-- stylesheets list from _config.yml -->
    
        <link rel="stylesheet" href="/css/style.css">
    



    <!-- scripts list from _config.yml -->
    
        <script src="/js/script.js"></script>
    
        <script src="/js/tocbot.min.js"></script>
    



    
    
        
    



    <script src='https://unpkg.com/mermaid@7.1.2/dist/mermaid.min.js'></script>
    <script>
        if (window.mermaid) {
            mermaid.initialize({theme: 'forest'});
        }
    </script>


<meta name="generator" content="Hexo 5.4.1"></head>

<body>
    <script>
        // this function is used to check current theme before page loaded.
        (() => {
            const currentTheme = window.localStorage && window.localStorage.getItem('theme') || '';
            const isDark = currentTheme === 'dark';
            const pagebody = document.getElementsByTagName('body')[0]
            if (isDark) {
                pagebody.classList.add('dark-theme');
                // mobile
                document.getElementById("mobile-toggle-theme").innerText = "· Dark"
            } else {
                pagebody.classList.remove('dark-theme');
                // mobile
                document.getElementById("mobile-toggle-theme").innerText = "· Light"
            }
        })();
    </script>

    <div class="wrapper">
        <header>
    <nav class="navbar">
        <div class="container">
            <div class="navbar-header header-logo"><a href="/">Janmas&#39;s Blog</a></div>
            <div class="menu navbar-right">
                
                    <a class="menu-item" href="/archives">Posts</a>
                
                    <a class="menu-item" href="/category">Categories</a>
                
                    <a class="menu-item" href="/tag">Tags</a>
                
                <input id="switch_default" type="checkbox" class="switch_default">
                <label for="switch_default" class="toggleBtn"></label>
            </div>
        </div>
    </nav>

    
    <nav class="navbar-mobile" id="nav-mobile">
        <div class="container">
            <div class="navbar-header">
                <div>
                    <a href="/">Janmas&#39;s Blog</a><a id="mobile-toggle-theme">·&nbsp;Light</a>
                </div>
                <div class="menu-toggle" onclick="mobileBtn()">&#9776; Menu</div>
            </div>
            <div class="menu" id="mobile-menu">
                
                    <a class="menu-item" href="/archives">Posts</a>
                
                    <a class="menu-item" href="/category">Categories</a>
                
                    <a class="menu-item" href="/tag">Tags</a>
                
            </div>
        </div>
    </nav>

</header>
<script>
    var mobileBtn = function f() {
        var toggleMenu = document.getElementsByClassName("menu-toggle")[0];
        var mobileMenu = document.getElementById("mobile-menu");
        if(toggleMenu.classList.contains("active")){
           toggleMenu.classList.remove("active")
            mobileMenu.classList.remove("active")
        }else{
            toggleMenu.classList.add("active")
            mobileMenu.classList.add("active")
        }
    }
</script>
            <div class="main">
                <div class="container">
    
    
        <div class="post-toc">
    <div class="tocbot-list">
    </div>
    <div class="tocbot-list-menu">
        <a class="tocbot-toc-expand" onclick="expand_toc()">Expand all</a>
        <a onclick="go_top()">Back to top</a>
        <a onclick="go_bottom()">Go to bottom</a>
    </div>
</div>

<script>
    document.ready(
        function () {
            tocbot.init({
                tocSelector: '.tocbot-list',
                contentSelector: '.post-content',
                headingSelector: 'h1, h2, h3, h4, h5',
                collapseDepth: 1,
                orderedList: false,
                scrollSmooth: true,
            })
        }
    )

    function expand_toc() {
        var b = document.querySelector(".tocbot-toc-expand");
        tocbot.init({
            tocSelector: '.tocbot-list',
            contentSelector: '.post-content',
            headingSelector: 'h1, h2, h3, h4, h5',
            collapseDepth: 6,
            orderedList: false,
            scrollSmooth: true,
        });
        b.setAttribute("onclick", "collapse_toc()");
        b.innerHTML = "Collapse all"
    }

    function collapse_toc() {
        var b = document.querySelector(".tocbot-toc-expand");
        tocbot.init({
            tocSelector: '.tocbot-list',
            contentSelector: '.post-content',
            headingSelector: 'h1, h2, h3, h4, h5',
            collapseDepth: 1,
            orderedList: false,
            scrollSmooth: true,
        });
        b.setAttribute("onclick", "expand_toc()");
        b.innerHTML = "Expand all"
    }

    function go_top() {
        window.scrollTo(0, 0);
    }

    function go_bottom() {
        window.scrollTo(0, document.body.scrollHeight);
    }

</script>
    

    
    <article class="post-wrap">
        <header class="post-header">
            <h1 class="post-title">vim键位整理</h1>
            
                <div class="post-meta">
                    
                        Author: <a itemprop="author" rel="author" href="/">Janmas</a>
                    

                    
                        <span class="post-time">
                        Date: <a href="#">January 25, 2022&nbsp;&nbsp;13:46:45</a>
                        </span>
                    
                    
                </div>
            
        </header>

        <div class="post-content">
            <p>如果你是初学者，我是不建议你直接看这一章节的，因为实在太多了，你会乱的。但是如果你已经用了很久 Vim，偶尔想看看以前没记牢的或者想看看哪些不知道的键位，一点一点翻以前的课程又会很浪费时间，所以我放出了这个章节，将所有的键位整理起来，以便查阅。</p>
<p>整理进度跟本书更新进度齐平。</p>
<ul>
<li>  <code>&lt;space&gt;</code> 空格键</li>
<li>  <code>&lt;cr&gt;</code> 回车</li>
<li>  <code>&lt;c-f&gt;</code> 表示 <code>&lt;ctrl&gt;</code> 和 <code>f</code> 的组合键</li>
</ul>
<h2 id="写入、保存、退出"><a href="#写入、保存、退出" class="headerlink" title="写入、保存、退出"></a>写入、保存、退出</h2><ol>
<li><p> <code>:q[uit] &quot; 退出</code></p>
</li>
<li><p> <code>:q!                     &quot; 强制退出</code></p>
</li>
<li><p> <code>:w[rite] &quot; 保存</code></p>
</li>
<li><p> <code>:w!                     &quot; 强制保存，能不能保存成功取决于用户对文件的权限</code></p>
</li>
<li><p> <code>:w ! sudo tee % &quot; 如果没有权限保存，试试这个命令</code></p>
</li>
<li><p> <code>ZZ                      &quot; 两个大写的 Z，没有修改直接退出，有修改保存后退出</code></p>
</li>
<li><p> <code>:w newfilename &quot; 另存为新文件</code></p>
</li>
<li><p> <code>:1, 10 w newfilename    &quot; 将 1 到 10 行的内容另存为新文件</code></p>
</li>
<li><p> <code>:1, 10 w &gt;&gt; filename &quot; 将 1 到 10 行的内容另存为新文件</code></p>
</li>
<li><p> <code>:r filename             &quot; 将目标文件的内容追加到当前光标下一行</code></p>
</li>
<li><p> <code>:3 r filename &quot; 将目标文件的内容追加到第 3 行一下</code></p>
</li>
<li><p> <code>:! ls                   &quot; 暂时离开 Vim 查看当前目录的文件，回车后返回 Vim</code></p>
</li>
</ol>
<h2 id="光标移动"><a href="#光标移动" class="headerlink" title="光标移动"></a>光标移动</h2><ol>
<li><p> <code>h &quot; 方向键 ←</code></p>
</li>
<li><p> <code>j           &quot; 方向键 ↓</code></p>
</li>
<li><p> <code>k &quot; 方向键 ↑</code></p>
</li>
<li><p> <code>l           &quot; 方向键 →</code></p>
</li>
<li><p> <code>0 &quot; 移动到行首</code></p>
</li>
<li><p> <code>$           &quot; 移动到行尾的回车符</code></p>
</li>
<li><p> <code>g_ &quot; 移动到行尾最后一个非空字符</code></p>
</li>
<li><p> <code>gg          &quot; 移动到第一行</code></p>
</li>
<li><p> <code>G &quot; 移动到最后一行&quot;</code></p>
</li>
<li><p> <code>w &quot; 移动到下一个单词开头</code></p>
</li>
<li><p> <code>e           &quot; 移动到单词的结尾</code></p>
</li>
<li><p> <code>b &quot; 移动到单词的开头</code></p>
</li>
<li><p> <code>&quot; 不常用</code></p>
</li>
<li><p> <code>nh &quot; 向左移动 n 格，n 为数字</code></p>
</li>
<li><p> <code>nl          &quot; 向右移动 n 格</code></p>
</li>
<li><p> <code>nj &quot; 向下移动 n 行</code></p>
</li>
<li><p> <code>nk          &quot; 向上移动 n 行</code></p>
</li>
<li><p> <code>n&lt;space&gt; &quot; 向右移动 n 格，同 nl</code></p>
</li>
<li><p> <code>H            &quot; 移动到当前屏幕第一行的第一个字符</code></p>
</li>
<li><p> <code>M &quot; 移动到当前屏幕中间行的第一个字符</code></p>
</li>
<li><p> <code>L            &quot; 移动到当前屏幕最后一行的第一个字符</code></p>
</li>
<li><p> <code>+ &quot; 移动到非空白字符的下一行</code></p>
</li>
<li><p> <code>-            &quot; 移动到非空白字符的上一行</code></p>
</li>
<li><p> <code>:n&lt;cr&gt; &quot; 跳转到第 n 行</code></p>
</li>
</ol>
<h2 id="翻页"><a href="#翻页" class="headerlink" title="翻页"></a>翻页</h2><ol>
<li> <code>&lt;c-f&gt; &quot; 向下移动一页</code></li>
<li> <code>&lt;c-d&gt; &quot; 向下移动半页</code></li>
<li> <code>&lt;c-b&gt; &quot; 向上移动一页</code></li>
<li> <code>&lt;c-u&gt; &quot; 向上移动半页</code></li>
</ol>
<h2 id="查找与替换"><a href="#查找与替换" class="headerlink" title="查找与替换"></a>查找与替换</h2><ol>
<li><p> <code>/word &quot; 从光标位置向下搜索 word 单词</code></p>
</li>
<li><p> <code>?word   &quot; 从光标位置向上搜索 word 单词</code></p>
</li>
<li><p> <code>n &quot; 英文字母 n，根据 / 或 ? 搜索的方向定位到下一个匹配目标</code></p>
</li>
<li><p> <code>N       &quot; 与 n 相反，定位匹配目标</code></p>
</li>
<li><p> <code>:n1,n2s/word1/word2/g &quot; n1, n2 表示数字，替换 n1 行到 n2 行的单词</code></p>
</li>
<li><p> <code>:1,$s/word1/word2/g     &quot; 全文替换，也可以写成 :%s/word1/word2/g</code></p>
</li>
<li><p> <code>:1,$s/word1/word2/gc &quot; 全文替换，并出现确认提示</code></p>
</li>
</ol>
<h2 id="复制、粘贴、删除"><a href="#复制、粘贴、删除" class="headerlink" title="复制、粘贴、删除"></a>复制、粘贴、删除</h2><ol>
<li><p> <code>x &quot; 向后删除一个字符</code></p>
</li>
<li><p> <code>nx          &quot; 向后删除 n 个字符</code></p>
</li>
<li><p> <code>X &quot; 向前删除一个字符</code></p>
</li>
<li><p> <code>nX          &quot; 向前删除 n 个字符</code></p>
</li>
<li><p> <code>dd &quot; 删除当前行</code></p>
</li>
<li><p> <code>ndd         &quot; 向下删除 n 行</code></p>
</li>
<li><p> <code>d1G / dgg &quot; 删除第一行到当前行的数据</code></p>
</li>
<li><p> <code>dG          &quot; 删除当前行到最后一行的数据</code></p>
</li>
<li><p> <code>d$ &quot; 删除当前字符到行尾</code></p>
</li>
<li><p> <code>D           &quot; 删除当前字符到行尾</code></p>
</li>
<li><p> <code>d0 &quot; 从行首删除到当前字符</code></p>
</li>
<li><p> <code>yy          &quot; 复制当前行</code></p>
</li>
<li><p> <code>Y &quot; 复制当前行</code></p>
</li>
<li><p> <code>nyy         &quot; 从当前行开始复制 n 行</code></p>
</li>
<li><p> <code>y1G / ygg &quot; 从第一行复制到当前行</code></p>
</li>
<li><p> <code>yG          &quot; 从当前行复制到最后一行</code></p>
</li>
<li><p> <code>y0 &quot; 从行首复制到当前字符</code></p>
</li>
<li><p> <code>y$          &quot; 从当前字符复制到行尾</code></p>
</li>
<li><p> <code>p, P &quot; 黏贴，p 黏贴到光标下一行，P 黏贴到光标上一行</code></p>
</li>
<li><p> <code>yyp         &quot; 复制并粘贴</code></p>
</li>
<li><p> <code>ddp &quot; 删除并粘贴，相当于下移当前行</code></p>
</li>
<li><p> <code>&quot;+y &quot; 复制本文到系统剪切板</code></p>
</li>
<li><p> <code>&quot;+p &quot; 粘贴系统剪切板到 Vim（不会影响文本格式）</code></p>
</li>
</ol>
<h2 id="插入"><a href="#插入" class="headerlink" title="插入"></a>插入</h2><ol>
<li><p> <code>i &quot; 在光标前进入 insert 模式</code></p>
</li>
<li><p> <code>I   &quot; 在当前行左边第一个非空字符前进入 insert 模式，类似其他编辑器的 &lt;c-a&gt; 快捷键</code></p>
</li>
<li><p> <code>a &quot; 在光标后进入 insert 模式</code></p>
</li>
<li><p> <code>A   &quot; 在当前行右边第一个非空字符前进入 insert 模式，类似其他编辑器的 &lt;c-e&gt; 快捷键</code></p>
</li>
<li><p> <code>o &quot; 在光标的下一行插入</code></p>
</li>
<li><p> <code>O   &quot; 在光标的上一行插入</code></p>
</li>
<li><p> <code>s &quot; 删除当前字符，并进入 insert 模式</code></p>
</li>
<li><p> <code>S   &quot; 删除当前行，并进入插入模式</code></p>
</li>
<li><p> <code>vc &quot; 删除当前字符，并进入 insert 模式</code></p>
</li>
<li><p> <code>cc  &quot; 删除当前行，并进入插入模式</code></p>
</li>
<li><p> <code>c0 &quot; 删除光标位置到行首，并进入 insert 模式</code></p>
</li>
<li><p> <code>cg_ &quot; 删除光标位置到行尾最后一个非空字符，并进入 insert 模式</code></p>
</li>
<li><p> <code>ce &quot; 删除光标位置到单词末尾，并进入 insert 模式</code></p>
</li>
<li><p> <code>cw  &quot; 删除光标位置到单词末尾，并进入 insert 模式</code></p>
</li>
<li><p> <code>ciw &quot; 删除当前单词，并进入 insert 模式</code></p>
</li>
<li><p> <code>cip &quot; 删除整个段落，并进入 insert 模式</code></p>
</li>
<li><p> <code>ci( &quot; 删除当前括号内的内容，并进入 insert 模式 适用于 ([&#123;&lt;&#39;` 等所有成对的标签</code></p>
</li>
</ol>
<h2 id="撤销重做"><a href="#撤销重做" class="headerlink" title="撤销重做"></a>撤销重做</h2><ol>
<li> <code>u &quot; 撤销</code></li>
<li> <code>&lt;c-r&gt;   &quot; 重做</code></li>
<li> <code>. &quot; 重复完成操作</code></li>
</ol>
<h2 id="替换"><a href="#替换" class="headerlink" title="替换"></a>替换</h2><ol>
<li> <code>r &quot; 替换单个字符，自动返回 normal 模式</code></li>
<li> <code>R   &quot; 连续替换多个字符，手动 &lt;esc&gt; 返回 normal 模式</code></li>
</ol>
<h2 id="大小写"><a href="#大小写" class="headerlink" title="大小写"></a>大小写</h2><ol>
<li><p> <code>~ &quot; 当前字符大小写反转</code></p>
</li>
<li><p> <code>g~~     &quot; 正行字符大小写反转</code></p>
</li>
<li><p> <code>vu &quot; 当前字符小写</code></p>
</li>
<li><p> <code>vU      &quot; 当前字符大写</code></p>
</li>
<li><p> <code>vU &quot; 当前字符大写</code></p>
</li>
<li><p> <code>viwu    &quot; 当前字符小写</code></p>
</li>
<li><p> <code>viwU &quot; 当前字符大写</code></p>
</li>
<li><p> <code>ggguG   &quot; 文本所有字符小写</code></p>
</li>
<li><p> <code>gggUG &quot; 文本所有字符大写</code></p>
</li>
<li><p> <code>:%s/\&lt;./\u&amp;/g       &quot; 将所有单词首字母大写（需要使用 :nohls 去掉高亮）</code></p>
</li>
<li><p> <code>:%s/\&lt;./\l&amp;/g &quot; 将所有单词首字母小写</code></p>
</li>
<li><p> <code>:%s/.*/\u&amp;          &quot; 将每行第一个字母大写</code></p>
</li>
<li><p> <code>:%s/.*/\l&amp; &quot; 将每行第一个字母小写</code></p>
</li>
</ol>
<h2 id="多窗口操作"><a href="#多窗口操作" class="headerlink" title="多窗口操作"></a>多窗口操作</h2><ol>
<li><p> <code>:sp filename &quot; 上下分割窗口</code></p>
</li>
<li><p> <code>:vs[p] filename     &quot; 左右分割窗口</code></p>
</li>
<li><p> <code>&lt;c-w&gt;h[j[k[l]]] &quot; 根据方向键移动光标到该方向的窗口上</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]&gt;           &quot; N 位数字，可选，增加当前窗口 N 列宽&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]&lt;           &quot; N 位数字，可选，减少当前窗口 N 列宽&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]+           &quot; N 位数字，可选，增加当前窗口 N 行高&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]-           &quot; N 位数字，可选，减少当前窗口 N 行高&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;=              &quot; 将所有窗口设置等宽高</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]n &quot; N 位数字，可选，打开一个新窗口 N 行高，默认为整个窗口的一半&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]s &quot; N 位数字，可选，将当前窗口垂直分割为上下两个窗口展示&quot;</code></p>
</li>
<li><p>  <code>&quot; 新窗口可以为 N 行高，默认为整个窗口的一半&quot;</code></p>
</li>
<li><p>  <code>&quot; 类似于 :sp current_file&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;[N]v &quot; N 位数字，可选，将当前窗口水平分割为左右两个窗口展示&quot;</code></p>
</li>
<li><p>  <code>&quot; 新窗口可以为 N 列宽，默认为整个窗口的一半&quot;</code></p>
</li>
<li><p>  <code>&quot; 类似于 :vs current_file&quot;</code></p>
</li>
<li><p> <code>&lt;c-w&gt;o &quot; 关闭除当前窗口外的所有窗口</code></p>
</li>
<li><p> <code>&lt;c-w&gt;r              &quot; 顺时针转动窗口</code></p>
</li>
<li><p> <code>&lt;c-w&gt;R &quot; 逆时针转动窗口</code></p>
</li>
<li><p> <code>&lt;c-w&gt;x              &quot; 对调左右或上下两个对应的窗口</code></p>
</li>
<li><p> <code>&lt;c-w&gt;q &quot; 退出窗口</code></p>
</li>
<li><p> <code>:q                  &quot; 退出窗口</code></p>
</li>
</ol>
<h2 id="多文件编辑"><a href="#多文件编辑" class="headerlink" title="多文件编辑"></a>多文件编辑</h2><ol>
<li><p> <code>vim file1 file2 &quot; 同时打开两个文件</code></p>
</li>
<li><p> <code>:files              &quot; 查看现在编辑的文件列表，%a 代表正在操作哪个文件</code></p>
</li>
<li><p>  <code>1 %a &quot;file1&quot; line 1</code></p>
</li>
<li><p>  <code>2 &quot;file2&quot; line 0</code></p>
</li>
<li><p> <code>:n &quot; 跳到下一个文件，这里的 n 就是字母</code></p>
</li>
<li><p> <code>:N                  &quot; 跳到上一个文件</code></p>
</li>
</ol>

        </div>

        
            <section class="post-copyright">
                
                
                
                

            </section>
        
        <section class="post-tags">
            <div>
                <span>Tag(s):</span>
                <span class="tag">
                    
                    
                        <a href="/tags/vim%E9%94%AE%E4%BD%8D/"># vim键位</a>
                    
                        <a href="/tags/vim%E5%AD%A6%E4%B9%A0/"># vim学习</a>
                    
                        
                </span>
            </div>
            <div>
                <a href="javascript:window.history.back();">back</a>
                <span>· </span>
                <a href="/">home</a>
            </div>
        </section>
        <section class="post-nav">
            
                <a class="prev" rel="prev" href="/2022/03/17/%E7%B4%A2%E5%BC%95%E5%8E%9F%E7%90%86/">索引原理</a>
            
            
            <a class="next" rel="next" href="/2022/01/13/hello-world/">Hello World</a>
            
        </section>


    </article>
</div>

            </div>
            <footer id="footer" class="footer">
    <div class="copyright">
        <span>© Janmas | Powered by <a href="https://hexo.io" target="_blank">Hexo</a> & <a href="https://github.com/Siricee/hexo-theme-Chic" target="_blank">Chic</a></span>
    </div>
</footer>



    </div>
</body>

</html>